package com.minglan.leetcode.java.solution2103;

import com.minglan.leetcode.java.pub.ArrayUtils;

/*
 * 2021.3.6
 * 503. 下一个更大元素 II
给定一个循环数组（最后一个元素的下一个元素是数组的第一个元素），输出每个元素的下一个更大元素。
数字 x 的下一个更大的元素是按数组遍历顺序，这个数字之后的第一个比它更大的数，这意味着你应该循环地搜索它的下一个更大的数。
如果不存在，则输出 -1。

示例 1:

输入: [1,2,1]
输出: [2,-1,2]
解释: 第一个 1 的下一个更大的数是 2；
数字 2 找不到下一个更大的数； 
第二个 1 的下一个最大的数需要循环搜索，结果也是 2。

 */
public class NextGreaterElements {
	
    public int[] nextGreaterElements(int[] nums) {
    	int[] ret=new int[nums.length];
    	for(int i=0;i<nums.length;i++) {
    		int j;
    		for(j=0;j<nums.length;j++) {
    			int k=j+i+1;
    			if(k>=nums.length) k-=nums.length;
    			System.out.println("j="+j + " k="+k);
    			if(nums[i]<nums[k]) {ret[i]=nums[k];break;}
    		}
    		if ( j==nums.length )
    			ret[i]=-1;
    	}
    	return ret;

    }
    
	public static void main(String[] args) {
		int[] m= {1,2,1};
		NextGreaterElements n = new NextGreaterElements();
		int[] r=n.nextGreaterElements(m);
		ArrayUtils.logarray(m);
		ArrayUtils.logarray(r);

	}

}
